Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Nix flake #1970

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

aidenfoxivey
Copy link
Contributor

@praveksharma @SWilson4 As I mentioned earlier, I wrote a little nix flake that should be able to run the environment without anything other than Nix installed on the machine - in addition to being declarative.

I'm happy to add or remove packages to the flake - I mostly followed the requirements for the QuickStart, but potentially missed something.

@baentsch
Copy link
Member

Thanks for the proposal @aidenfoxivey ! Quick initial question (not knowing anything about nix): Does this have to reside in the top level project directory?

@aidenfoxivey
Copy link
Contributor Author

Hi @baentsch!

In every project I've worked on, flake.nix and flake.lock do reside in the top level. That said, I was curious about the question, so I looked it up.

According to this reference (https://nixos.wiki/wiki/Flakes), flake.nix does have to be in the top-level.

My main goal with this is to have a declarative way to build liboqs to aid debugging and avoid having to use containers.

@aidenfoxivey aidenfoxivey marked this pull request as ready for review October 31, 2024 20:16
@SWilson4
Copy link
Member

SWilson4 commented Nov 5, 2024

Thanks for the submission @aidenfoxivey!

I personally don't know anything about Nix, but I think two non–Nix-related issues would need to be resolved before this lands:

  1. The flake should be tested in CI somehow.
  2. There should be some sort of maintenance commitment to ensure the flake stays up to date—would you be willing to take this on?

flake.nix Outdated Show resolved Hide resolved
@aidenfoxivey
Copy link
Contributor Author

  1. The flake should be tested in CI somehow.
    Sounds good! I'll write up a little testing setup sometime this week.
  1. There should be some sort of maintenance commitment to ensure the flake stays up to date—would you be willing to take this on?
    Absolutely! I'm happy to be the designated flake maintainer.

@praveksharma praveksharma self-requested a review November 5, 2024 17:13
Copy link
Member

@praveksharma praveksharma left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The flake itself looks good to me, thank you @aidenfoxivey!

Could you also update the quickstart section of README.md to include instruction on how to use the flake?

Do you know if there's some way of parameterising the flake to spin up different dev envs, say with clang instead of gcc?

@aidenfoxivey
Copy link
Contributor Author

aidenfoxivey commented Nov 5, 2024

Could you also update the quickstart section of README.md to include instruction on how to use the flake?

I'll remove the instructions from the flake and put them in the quickstart along with other information.

Do you know if there's some way of parameterising the flake to spin up different dev envs, say with clang instead of gcc?

I'll take a look!

@aidenfoxivey
Copy link
Contributor Author

I think it's maybe better to version the flake starting from 0.0.1, but alternative perspectives are certainly appreciated.

@aidenfoxivey
Copy link
Contributor Author

Not sure what I did to boggle the code formatting lol. Maybe something in how I did the README was an issue?

README.md Outdated Show resolved Hide resolved
@aidenfoxivey
Copy link
Contributor Author

@baentsch I'll look into generating it by default

flake.nix Outdated Show resolved Hide resolved
result Outdated Show resolved Hide resolved
flake.nix Outdated Show resolved Hide resolved
README.md Outdated Show resolved Hide resolved
@aidenfoxivey
Copy link
Contributor Author

Turns out the version tag is completely unnecessary, since it can be referred to by its git hash anyways. I'll wait for additional comments and then clean up the git history once I've sorted out any requests.

@aidenfoxivey aidenfoxivey force-pushed the add-nix-flake branch 3 times, most recently from 13d5c87 to 729315f Compare November 6, 2024 23:47
Signed-off-by: Aiden Fox Ivey <[email protected]>
Copy link
Contributor

@cothan cothan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LTGM! Thanks for the contribution. Please make sure the all the tests are passed before you merge.

@aidenfoxivey aidenfoxivey requested a review from SWilson4 November 8, 2024 00:20
Copy link
Member

@praveksharma praveksharma left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good, thank for you working on this @aidenfoxivey!

@baentsch
Copy link
Member

baentsch commented Nov 8, 2024

LTGM! Thanks for the contribution. Please make sure the all the tests are passed before you merge.

Hmm -- this statement made me curious: What tests are there (to be) passed? I didn't find any (just searching for changes to .github/workflows). Wouldn't that/having such be prudent, @cothan @praveksharma ?

@cothan
Copy link
Contributor

cothan commented Nov 8, 2024

Hi @baentsch , I approve the PR while there are 6 tests (unrelated to the PR) are still running, since this PR doesn't add anything to Github flow, thus I expect them all to pass, and they did (I didn't aware at the time that each PR needs 2 approval). So I comment to make sure this PR will be merged in a green state.

@praveksharma
Copy link
Member

I agree that having testing for the flake would be desirable @baentsch but I'm also uncertain what is the best way to go about it. I believe the current build targets are limited in that they don't allow the user to pass CMake options via the nix CLI; is that correct @aidenfoxivey?

Since the project doesn't plan on moving away from CMake, at this stage it might make more sense to focus on developer quality of life improvement via nix develop. This would be easy to test via a weekly CI job -- on a ubuntu:latest image with just nix that must pass some cmake build tests.

Alternatively, if there is some way of transparently exposing CMake options to nix that would also be suitable. Instead of a maintainer having to ensure compatibility with CONFIGURE.md that would be handled natively by nix.

@aidenfoxivey
Copy link
Contributor Author

I believe the current build targets are limited in that they don't allow the user to pass CMake options via the nix CLI; is that correct @aidenfoxivey?

It's not strictly impossible, but it's only possible with some pretty unpleasant hacks or writing your own Nix code. I see the nix build workflow as ideally being the "canonical" configuration. (Like the one that the average person wants to build. Maybe common case is the right word.)

Copy link
Member

@baentsch baentsch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

uncertain what is the best way to go about it

OK, understood -- if we are in agreement, though, that tests should be added for a feature announced in the toplevel README (?) then there must be a way for it to happen -- and just doing it in a weekly test sounds wrong to me for a feature "prominently" announced/documented.

So I see two options:

  1. Remove reference to Nix from the README (basically aligning its untested status with the contents of PLATFORMS.md, i.e., where it's not mentioned as a supported environment)
  2. Add testing and a suitable (level) reference to PLATFORMS.md

@aidenfoxivey
Copy link
Contributor Author

Hmm. These are good points.

My feeling about PLATFORMS.md is that it's a tiny bit complex given that Nix works on

  • aarch64-darwin
  • aarch64-linux
  • i686-linux
  • x86_64-darwin
  • x86_64-linux

but we also don't want to require Nix to build anything. I view it less as a platform and more as a way to develop your own tooling AND build liboqs deterministically.

I'd prefer to mention it in the README just because it seems a shame to not mention it given that it can let you develop liboqs without having to worry about installing all the dependencies in your package manager.

@baentsch
Copy link
Member

baentsch commented Nov 9, 2024

it seems a shame to not mention it given that it can let you develop liboqs without having to worry about installing all the dependencies in your package manager

Agreed. What about adding an entry to Nix to https://github.com/open-quantum-safe/liboqs/wiki/Platform-specific-notes-for-building-liboqs instead of the explicit README mention? But then again, I'm anyway not particularly happy about having this information in the Wiki and not the core repo (so that it makes it into releases). Upon re-reading the README I've got to say the "Quickstart" is not exactly "quick", surely not short, so this PR is making life easier for folks using Nix (a link to Nix in the documentation --wherever that winds up-- would by good in any case).

What about this thought @SWilson4 : Make the Linux/Mac quickstart section as short as the Windows one (basically just list apt get ... && cmake), pointing to a more complete documentation (current detail level) elsewhere? Add a one-liner for Nix there and more complete Nix options (as in this PR) at where the complete text for Linux/Mac winds up? This way, the Quickstart gets truly quick again (for people that know the tooling -- and the ones that don't have to read below).

@praveksharma
Copy link
Member

"canonical" configuration. (Like the one that the average person wants to build. Maybe common case is the right word.)

I think this makes sense, I think this can also be expanded to include a set of common configurations in the future. That said, I think avoiding build options for now and including them in another PR after we've had a chance to think about suitable methods for testing them makes more sense.

Make the Linux/Mac quickstart section as short as the Windows one

I think this also makes sense but perhaps doing all of that here is out of the scope for this PR. Instead, if this PR chooses to just focus on deterministically setting up the dev environment then the "1. Install dependencies:" step under Linux and Mac can be edited to include a new "With Nix:" sub-sections. If that's okay I can create a new issue to track the streamlining of the Quick Start section.

How does that sound @aidenfoxivey @baentsch ?

@aidenfoxivey
Copy link
Contributor Author

This sounds reasonable to me!

@aidenfoxivey
Copy link
Contributor Author

@praveksharma Just to be clear, you want changes on the README, right?

@praveksharma
Copy link
Member

@praveksharma Just to be clear, you want changes on the README, right?

Yes, listing the relevant nix alternatives to the apt commands under Quick Start > Linux and Mac > 1. Install dependencies is what I had in mind.

@baentsch
Copy link
Member

As part of my year-end review of stalled things, can I ask what the idea is with this PR:

  • Add CI testing as per @SWilson4 's suggestion?
  • Add a small(er) README section as per @praveksharma 's suggestion (also addressing my concerns)
  • Drop PR without merge

Which of these options would you like to pursue, @aidenfoxivey ? One, all, none, something else?

@aidenfoxivey
Copy link
Contributor Author

As part of my year-end review of stalled things, can I ask what the idea is with this PR:

  • Add CI testing as per @SWilson4 's suggestion?
  • Add a small(er) README section as per @praveksharma 's suggestion (also addressing my concerns)
  • Drop PR without merge

Which of these options would you like to pursue, @aidenfoxivey ? One, all, none, something else?

Ah whoops! I've got to admit liboqs slipped by mind a little bit during the latter half of the term. I'm going to sort out the README section tonight.

Thinking about testing, I think I wrote a solution but never pushed it.

I'll look to wrap this up in the next few days.

Signed-off-by: Aiden Fox Ivey <[email protected]>
@aidenfoxivey
Copy link
Contributor Author

So I think there are a few things to think about:

  • is the Nix flake formatted? (this doesn't seem that important to me)
  • is it valid nix?
  • does the build it produces work?

Are all of these in scope for what tests should do?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants